cd命令
这是一个非常基本,也是大家经常需要使用的命令,它用于切换当前目录,它的参数是要切换到的目录的路径,可以是绝对路径,也可以是相对路径。如:
1 | cd /root/Docements # 切换到目录/root/Docements |
ls命令
这是一个非常有用的查看文件与目录的命令,list之意,它的参数非常多,下面就列出一些我常用的参数吧,如下:
1 | -l :列出长数据串,包含文件的属性与权限数据等 |
注:这些参数也可以组合使用,下面举两个例子:
1 | ls -l #以长数据串的形式列出当前目录下的数据文件和目录 |
grep命令
该命令常用于分析一行的信息,若当中有我们所需要的信息,就将该行显示出来,该命令通常与管道命令一起使用,用于对一些命令的输出进行筛选加工等等,它的简单语法为
1 | grep [-acinv] [--color=auto] '查找字符串' filename |
它的常用参数如下:
1 | -a :将binary文件以text文件的方式查找数据 |
find命令
find是一个基于查找的功能非常强大的命令,相对而言,它的使用也相对较为复杂,参数也比较多,所以在这里将给把它们分类列出,它的基本语法如下:
1 | find [PATH] [option] [action] |
- 与时间有关的参数:
1 | -mtime n : n为数字,意思为在n天之前的“一天内”被更改过的文件; |
- 与用户或用户组名有关的参数:
1 | -user name : 列出文件所有者为name的文件 |
- 与文件权限及名称有关的参数:
1 | -name filename :找出文件名为filename的文件 |
cp命令
该命令用于复制文件,copy之意,它还可以把多个文件一次性地复制到一个目录下,它的常用参数如下:
1 | -a :将文件的特性一起复制 |
mv命令
该命令用于移动文件、目录或更名,move之意,它的常用参数如下:
1 | -f :force强制的意思,如果目标文件已经存在,不会询问而直接覆盖 |
rm命令
该命令用于删除文件或目录,remove之间,它的常用参数如下:
1 | -f :就是force的意思,忽略不存在的文件,不会出现警告消息 |
ps命令
该命令用于将某个时间点的进程运行情况选取下来并输出,process之意,它的常用参数如下:
1 | -A :所有的进程均显示出来 |
kill命令
该命令用于向某个工作(jobnumber)或者是某个PID(数字)传送一个信号,它通常与ps和jobs命令一起使用,它的基本语法如下:
1 | kill -signal PID |
killall命令
该命令用于向一个命令启动的进程发送一个信号,它的一般语法如下:
1 | killall [-iIe] [command name] |
file命令
该命令用于判断接在file命令后的文件的基本数据,因为在Linux下文件的类型并不是以后缀为分的,所以这个命令对我们来说就很有用了,它的用法非常简单,基本语法如下:
1 | file filename |
tar命令
该命令用于对文件进行打包,默认情况并不会压缩,如果指定了相应的参数,它还会调用相应的压缩程序(如gzip和bzip等)进行压缩和解压。它的常用参数如下:
1 | -c :新建打包文件 |
cat命令
该命令用于查看文本文件的内容,后接要查看的文件名,通常可用管道与more和less一起使用,从而可以一页页地查看数据。例如:
1 | cat text | less # 查看text文件中的内容 |
chgrp命令
该命令用于改变文件所属用户组,它的使用非常简单,它的基本用法如下:
1 | chgrp [-R] dirname/filename |
chown命令
该命令用于改变文件的所有者,与chgrp命令的使用方法相同,只是修改的文件属性不同,不再详述。
chmod命令
该命令用于改变文件的权限,一般的用法如下:
1 | chmod [-R] xyz 文件或目录 |
vim命令
该命令主要用于文本编辑,它接一个或多个文件名作为参数,如果文件存在就打开,如果文件不存在就以该文件名创建一个文件。vim是一个非常好用的文本编辑器,它里面有很多非常好用的命令,在这里不再多说。你可以从这里下载vim常用操作的详细说明。
gcc命令
对于一个用Linux开发C程序的人来说,这个命令就非常重要了,它用于把C语言的源程序文件,编译成可执行程序,由于g++的很多参数跟它非常相似,所以这里只介绍gcc的参数,它的常用参数如下:
1 | -o :output之意,用于指定生成一个可执行文件的文件名 |
time命令
该命令用于测算一个命令(即程序)的执行时间。它的使用非常简单,就像平时输入命令一样,不过在命令的前面加入一个time即可,例如:
1 | time ./process |
注:用户CPU时间和系统CPU时间之和为CPU时间,即命令占用CPU执行的时间总和。实际时间要大于CPU时间,因为Linux是多任务操作系统,往往在执行一条命令时,系统还要处理其它任务。另一个需要注意的问题是即使每次执行相同命令,但所花费的时间也是不一样,其花费时间是与系统运行相关的。
nohup
使用nohup命令后台运行命令之后,需要使用 exit 正常退出当前账户,这样才能保证命令一直在后台运行。
1 | nohup command & |
关闭中断后,在另一个终端 jobs 已经无法看到后台跑得程序了,此时利用ps(进程查看命令)1
ps -aux | grep "test.sh" #a:显示所有程序 u:以用户为主的格式来显示 x:显示所有程序,不以终端机来区分
如果使用nohup命令提交作业,那么在缺省情况下该作业的所有输出都被重定向到一个名为nohup.out的文件中,除非另外指定了输出文件:
1 | nohup command > myout.file 2>&1 & |
ctrl + z 可以将一个正在前台执行的命令放到后台,并且处于暂停状态。
Ctrl+c 终止前台命令。
jobs 查看当前有多少在后台运行的命令。 jobs -l选项可显示所有任务的PID,jobs的状态可以是running, stopped, Terminated。但是如果任务被终止了(kill),shell 从当前的shell环境已知的列表中删除任务的进程标识。
fg
将后台中的命令调至前台继续运行。如果后台中有多个命令,可以用fg %jobnumber(是命令编号,不是进程号)将选中的命令调出。
bg
将一个在后台暂停的命令,变成在后台继续执行。如果后台中有多个命令,可以用bg %jobnumber将选中的命令调出。
将任务转移到后台运行:
先ctrl + z;再bg,这样进程就被移到后台运行,终端还能继续接受命令。
2>&1
- command>out.file是将command的输出重定向到out.file文件,即输出内容不打印到屏幕上,而是输出到out.file文件中。
- 2>&1 是将标准出错重定向到标准输出,这里的标准输出已经重定向到了out.file文件,即将标准出错也输出到out.file文件中。最后一个&, 是让该命令在后台执行。
- 试想2>1代表什么,2与>结合代表错误重定向,而1则代表错误重定向到一个文件1,而不代表标准输出;换成2>&1,&与1结合就代表标准输出了,就变成错误重定向到标准输出.